<template>
  <a-table
    size="middle"
    :data-source="list"
    :columns="columns"
    :pagination="false"
    bordered
    :rowKey="(record, index) => index"
  >
    <template #title>
      <a-space>
        <a-input v-model="listQuery['name']" @pressEnter="loadData" placeholder="名称" class="search-input-item" />
        <a-input v-model="listQuery['networkId']" @pressEnter="loadData" placeholder="id" class="search-input-item" />

        <a-button type="primary" @click="loadData" :loading="loading">搜索</a-button>
      </a-space>
    </template>

    <a-tooltip #Created slot-scope="text" placement="topLeft" :title="text['Created']">
      <span>{{ parseTime(text['Created']) }}</span>
    </a-tooltip>
    <a-tooltip
      #ipam
      slot-scope="text"
      placement="topLeft"
      :title="`${text && text.driver}  ${
        text &&
        text.config
          .map((item) => {
            return ('网关：' + item.gateway || '') + '#' + ('子网掩码：' + item.subnet || '')
          })
          .join(',')
      }`"
    >
      <span>{{
        text &&
        text.config
          .map((item) => {
            return (item.gateway || '') + '#' + (item.subnet || '')
          })
          .join(',')
      }}</span>
    </a-tooltip>

    <a-tooltip #tooltip slot-scope="text" placement="topLeft" :title="text">
      <span>{{ text }}</span>
    </a-tooltip>

    <a-tooltip #id slot-scope="text" :title="text">
      <span> {{ text.split(':')[1].slice(0, 12) }}</span>
    </a-tooltip>
    <template #operation slot-scope="text, record">
      <a-space>
        <!-- <a-tooltip title="停止" v-if="record.state === 'running'">
          <a-button size="small" type="link" @click="doAction(record, 'stop')"><a-icon type="stop" /></a-button>
        </a-tooltip>
        <a-tooltip title="启动" v-else>
          <a-button size="small" type="link" @click="doAction(record, 'start')"> <a-icon type="play-circle" /></a-button>
        </a-tooltip>
        <a-tooltip title="重启">
          <a-button size="small" type="link" :disabled="record.state !== 'running'" @click="doAction(record, 'restart')"><a-icon type="reload" /></a-button>
        </a-tooltip> -->
        <a-tooltip title="删除">
          <a-button size="small" type="link" @click="doAction(record, 'remove')"><a-icon type="delete" /></a-button>
        </a-tooltip>
      </a-space>
    </template>
  </a-table>
</template>
<script>
import { renderSize, parseTime } from '@/utils/const'
import { dockerNetworksList, dockerVolumesRemove } from '@/api/docker-api'
export default {
  props: {
    id: {
      type: String,
      default: ''
    },
    urlPrefix: {
      type: String
    },
    machineDockerId: {
      type: String,
      default: ''
    }
  },
  data() {
    return {
      list: [],
      loading: false,
      listQuery: {
        dangling: false
      },
      renderSize,
      columns: [
        {
          title: '序号',
          width: 80,
          ellipsis: true,
          align: 'center',
          customRender: (text, record, index) => `${index + 1}`
        },
        { title: '名称', dataIndex: 'name', ellipsis: true, scopedSlots: { customRender: 'tooltip' } },
        { title: 'id', dataIndex: 'id', ellipsis: true, scopedSlots: { customRender: 'tooltip' } },
        { title: '范围', dataIndex: 'scope', ellipsis: true, scopedSlots: { customRender: 'tooltip' } },
        { title: 'IPAM', dataIndex: 'ipam', ellipsis: true, scopedSlots: { customRender: 'ipam' } },
        { title: '类型', dataIndex: 'driver', ellipsis: true, width: 80, scopedSlots: { customRender: 'tooltip' } },
        {
          title: '创建时间',
          dataIndex: 'rawValues',
          ellipsis: true,
          width: 180,
          sorter: (a, b) => new Date(a.rawValues.Created).getTime() - new Date(b.rawValues.Created).getTime(),
          sortDirections: ['descend', 'ascend'],
          defaultSortOrder: 'descend',
          scopedSlots: { customRender: 'Created' }
        }
        // { title: "操作", dataIndex: "operation", scopedSlots: { customRender: "operation" }, width: 80 },
      ],
      action: {
        remove: {
          msg: '您确定要删除当前卷吗？',
          api: dockerVolumesRemove
        }
      }
    }
  },
  computed: {
    reqDataId() {
      return this.id || this.machineDockerId
    }
  },
  mounted() {
    this.loadData()
  },
  methods: {
    parseTime,
    // 加载数据
    loadData() {
      this.loading = true
      //this.listQuery.page = pointerEvent?.altKey || pointerEvent?.ctrlKey ? 1 : this.listQuery.page;
      this.listQuery.id = this.reqDataId
      dockerNetworksList(this.urlPrefix, this.listQuery).then((res) => {
        if (res.code === 200) {
          this.list = res.data
        }
        this.loading = false
      })
    },
    doAction(record, actionKey) {
      const action = this.action[actionKey]
      if (!action) {
        return
      }
      $confirm({
        title: '系统提示',
        content: action.msg,
        okText: '确认',
        cancelText: '取消',
        onOk: () => {
          // 组装参数
          const params = {
            id: this.reqDataId,
            volumeName: record.name
          }
          action.api(this.urlPrefix, params).then((res) => {
            if (res.code === 200) {
              $notification.success({
                message: res.msg
              })
              this.loadData()
            }
          })
        }
      })
    }
  }
}
</script>
